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(54) Extending hypermedia documents by adding tagged attributes 



(57) Undefined tags and tag attributes are embed- 
ded in a web page written in HTML. The web page in- 
cludes a script which interprets the undefined attributes 
to perform a predefined action. The undefined tag at- 
tributes can refer to elements of a data source such as 
a stock and the current value of the stock. The interpret- 
ed attributes are used to retrieve the stock and value of 
Interest from a real-time data source, and to write the 
values into the web page, so that they are displayed in 
the form of a real-time data stream. 
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Description 

[0001] This invention relates to the field of hypermedia document mark-up languages, and includes the provision of 
arbitrary extensions to hypertext markup language (HTML), particularly but not exclusively for providing real-time data 

5 streaming to a web page. 

[0002] The World Wide Web is based on hypertext, which can be thought of as text which is not constrained to be 
sequential. The Web can handle much more than just text, so the more general term hypermedia Is used to cover all 
types of content, including but not limited to pictures, graphics, sound and video. While the primary language for rep- 
resenting hypermedia content on the Web is HTML, other markup languages are constantly developing, including, for 

10 example, XML. The term hypermedia as used herein is therefore not intended to be limited to any particular web 
language, nor indeed to the World Wide Web, but should be interpreted as a general term which can also refer to 
content on public or private networks which operate according to Hypertext Transfer Protocol (HTTP) or other similar 
protocols. 

[0003] As mentioned above, HTML is a document mark-up language which is the primary language for creating 
15 documents on the World Wide Web. It defines the structure and layout of a Web document by reference to a number 
of pre-defined tags with associated attributes. The tags and attributes are interpreted and the web page is accordingly 
displayed by a client application running on a computer, commonly referred to as a browser. 

[0004] Although the use of HTML on Its own produces essentially static Web pages, it Is well known to use scripting 
languages such as Javascript to enhance HTML functionality; the combination is often referred to as Dynamic HTML. 

20 The current generation of browsers use a document object model (DOM) to represent web pages internally. This makes 
all of the content on a page available to scripting code and enables programmers to build documents, navigate their 
structure and add, modify or delete elements and content. In general, however, any non-standard behaviour in a page 
must be implemented by custom programming in a language other than the markup language, and the nature of such 
behaviour cannot be specified or governed from within the markup language itself, even if, as in the case of XML, that 

25 language is inherently extensible. The present invention seeks to address this limitation. 

[0005] According to the present invention, there is provided a method of processing a hypermedia document, the 
document comprising information defined in a hypermedia markup language, information which is undefined in the 
hypermedia markup language and program instructions, the method comprising executing the program instructions to 
perform a predetermined function in dependence on the undefined information. 

30 [0006] The program instructions can be defined in a scripting language. 

[0007] The undefined information can be embedded in the defined information, for example as additional attributes 
of a tag which Is defined In the markup language, and the method can further comprise extracting the undefined Infor- 
mation from the defined information. For instance, the method can comprise searching for the tag and then searching 
for and extracting the additional attributes. 

35 [0008] Advantageously, the method according to the invention provides a way of controlling the behaviour of the 
program executing within the hypermedia document by implementing a non-standard tag or adding attributes to a 
standard tag. 

[0009] The undefined information can be referenced through a document object model created from the hypermedia 
document by a client application, such as a web browser and the method can comprise searching the document object 
40 model for the undefined information. 

[0010] The method can also include retrieving data to be displayed from an external source in dependence on the 
undefined information. By retrieving real-time data periodically, or receiving it continuously in response to a request 
for the data, real-time streaming can be achieved for display by a web browser. 

[001 1] According to the invention, there is further provided a hypermedia document for display by a client application. 
45 the document including information defined in a hypermedia markup language, information which is undefined in the 
hypermedia markup language and program instructions, the program Instructions being executable to perform a pre- 
determined function in dependence on the undefined information. 

[0012] The defined information can include a tag having defined attributes and the undefined information can com- 
prise additional undefined attributes for the tag. The creation of additional attributes in this way, or the creation of 
50 entirely non-standard extension tags, can permit arbitrary extensions to the markup language in use, without having 
to follow the constraints imposed by the structure or syntactical requirements of the language or the restrictions imposed 
by the browser software. 

[001 3] In an advantageous example, the undefined attributes can index elements of a data source, which can permit 
real-time streaming of data into a location in the hypermedia document, whereby said data can be displayed. 
55 [0014] According to the invention, there is also provided a method of providing real-time information for display as 
a hypermedia document, the document including a tag defining the location at which the information is to be displayed, 
the tag being associated with at least one attribute, comprising retrieving the information to be displayed In dependence 
on the one or more attributes associated with the tag and writing the information to the predefined location in the 
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hypermedia document. 

[001 5] The invention also provides a system for displaying information, comprising means for accessing a hyperme- 
dia document, a client application for displaying the hypermedia document, program means associated with the hy- 
permedia document for Interpreting information within the hypermedia document which Is not Interpretable by the client 

5 application, and means for receiving information to be displayed in response to said interpretation. The hypermedia 
document can include a tag defining the location at which the information is to be displayed, the tag being associated 
with at least one attribute which Is interpretable by the client application, the information which Is not interpretable by 
the client application can comprise additional attributes associated with the tag which index the data to be displayed. 
[0016] Embodiments of the invention will now be described by way of example with reference to the accompanying 

10 drawings, in which: 

Figure 1 is a schematic diagram of an Internet based system; 
Figure 2 is a schematic diagram of the architecture of a typical computer; 
Figure 3 illustrates a document object model corresponding to a first code extract; 
is Figure 4 illustrates a document object model corresponding to a second code extract; 

Figure 5 is a flow chart illustrating the function of a Javascript program configured to define the function of an 
extension tag; 

Figure 6 is a screen-shot of a web page which uses extension tags to display real-time market data; and 
Figure 7 is a flow chart describing the placement of real-time financial information onto a web page in accordance 
20 with the invention. 

[001 7] Figure 1 is a schematic diagram of an Internet based system in which a client computer 1 connects to a server 
computer 2 via the Internet 3. The client computer 1 is capable of running browser software 4, for example, Internet 
Explorer™ or Netscape Navigator™ for viewing web pages provided by web server software 5 at server computer 2. 
25 A further server computer 6, referred to herein as an RTTP server, provides a source of real-time data and its func- 
tionality will be described in detail below. 

[0018] The client computer 1 and server computers 2, 6 are conventional computers, an example architecture for 
which is shown in Figure 2. Each computer 1 , 2 comprises a central processing unit (CPU) 7 for executing computer 
programs and managing and controlling the operation of the computer. The CPU 7 is connected to a number of devices 

30 via a bus 8, the devices including a read/write device 9, for example a floppy disk drive for reading and writing data 
and computer programs to and from a removable storage medium such as a floppy disk 10, a storage device 11 , for 
example a hard disk drive for storing system and application software, a CD-ROM drive 12 and memory devices in- 
cluding ROM 13 and RAM 14. The computer further includes a network card 15 for interfacing to a network 3 and user 
input/output devices, such as a mouse 16, keyboard 1 7 and display 18. It will be understood by the skilled person that 

35 the above described architecture is not limiting, but is merely an example of a typical computer architecture. It will be 
further understood that the described computer has all the necessary operating system and application software to 
enable it to fulfil its purpose. 

[001 9] As mentioned above, the current generation of web browsers represent the content and format of web pages 
as a document object model (DOM). The DOM is an application programming interface (API) for documents which 

4p defines the logical structure of documents and the way a document is accessed or manipulated. The DOM specification 
is under constant development by the Wo rid Wide Web Consortium (W3C), but it is currently implemented differently 
depending on the browser software being used, so that access to and manipulation of the elements on a web page is 
browser type and browser version specific. DOMs are implemented by, for example, Internet Explorer version 4 and 
above and Netscape Navigator version 6. 

45 [0020] For example, the HTML extract shown as Code Extract 1 below is represented by the document object model 
shown in Figure 3. 



50 



55 
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<table> 

<tbody> 

<tr> 

<td>over</td> 

<td>under</td> 

</tr> 

<tr> 



<td>up</td> 

<td>down</td> 

</tr> 

</tbody> 

</table> 



Code Extract 1 



30 [0021] All the content of an HTML document is represented in the document object model, including tags or attributes 
that the browser does not understand i.e. that are not part of the HTML specification or not supported by the browser 
being used. Such tags or attributes are also referred to herein as being undefined. When It comes across such tags 
or attributes, the browser adds them to the document object model but takes no further action. These tags or attributes 
are given meaning by means of a script that is included in the web page and runs within the client browser. The script 

35 identifies the new tag names and attributes and implements the actions specified by the tags. The HTML extract shown 
in Code Extract 2 below illustrates the use of a non-standard tag, also referred to herein as an extension tag. The 
extension tag EXTN_TAG (attribl, attrib2), where attribl and attrib2 represent pre-defined attributes, is unknown to 
an HTML browser, which nevertheless stores the tag within a document object model structure shown schematically 
in Figure 4. Figure 4 also illustrates the storage of the tag attributes within the document object model. 

40 

<body> 

45 

<extn_tag attribl « x attrib 2 = y></extn_tag> 
<ocher tags> 

50 <script src«[url of script at server]></script> 

</body> 



Code Extract 2 

55 

[0022] The SCRIPT tag in the Code Extract 2 above directs the browserto import and execute the Javascript program 
stored at the server address provided. A flowchart illustrating the operation of this program is shown In Figure 5. 
[0023] Referring to Figure 5, the program gets a tag (step s1), determines whether it is an extension tag (step s2) 
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and if not, gets the next tag (step s1). If the tag is an extension tag, the program gets the attributes attribl and attrib2 
(step s3) and then executes some action which is predefined in relation to the extension tag and its attributes (step 
s4). The process is repeated until the last tag has been found (step s5). Many different types of extension tags can be 
created in this way, each associated with an action or sequence of actions pre-defined by the user. A whole tag need 
not be created: the user can instead define one or more additional attributes to be added to an existing HTML tag and 
search for those additional attributes on each occurrence of the known tag. 

[0024] An example of a particular application which uses user-defined attributes within standard tags to provide for 
the inclusion of real-time data on a web page, is described below with reference to Figures 1 , 6 and 7. 
[0025] Figure 6 is a screen-shot of a web page which uses extension tags in accordance with the invention to im- 
plement an Information service which displays real-time market data. Referring again to Figure 1 , a subscriber to the 
information service views the web page by using browser software 4 on his computer 1 to connect to the web server 
5 running on the server machine 2. The HTML code underlying the web page shown in Figure 6 is shown as Code 
Extract 3 below. 

<hnnl> 

<body bgcolor =white> 
<oenter> 

<pstyle="font:bold 14px verdana, sans-serif" > 
</p> 

<table width =200 style = "font: 12px yerdana,sans-serif* > 
<tr sly^e= ,, font-weight:bold;backg^ound:silver s, > 
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<td width - 34%> Symbol< /td> 

<td width=33% align=right>Bid</td> 

<tdwidth=33% align = right >Ask</td> 

</tr> 
<tr> 

<td>GBP</td> 

<td align=right id=QUOTE symbol="GBP» fid="Bid" > <M> 
<td align-right id=QUOTE symbol="GBP" fid='Ask"> <Ad> 

</tr> 
<tr> 

<td>EUR</td> 

<td align=right id=QUOTE symbol- "EUR" fid -"Bid" > <Ad> 
<td align=right id=QUOTE symbol="EUR" fid =" Ask" > <Ad> 

</tr> 
<tr> 

<td>JPY</td> 

<td align-right id-QUOTE symbol- "JPY" fid-"Bid" > <M> 
<td align-right id-QUOTE symbol- "JPY" fid="Ask"> <M> 

</tr> 
</table> 
</ccnter> 

<script src- http:/ /data.rttp.com/ rtml ></script > 

</body> 

</html> 



Code Extract 3 

[0026] The only non-standard HTML elements in the code extract above appear in some of the <td> tags, which are 
identified by the attribute id=QUOTE, as will be described in more detail below. The non-standard elements are the 
additional attributes 'symbol' and fid', which specify how live data is to be displayed. The <script> tag provides the 
functionality which permits the operation of this example. The general format of the <script> tag is shown below: 
<script language=javascript src=urt [attributel attribute2 ... ]> </script> 

[0027] The "src" attribute points to the url of the directory containing the program, written for example in Javascript, 
which provides the functionality according to the invention. 

[0028] Optional attributes are provided for the < script > tag which permit modification of default behaviour. These 
are obtained and interpreted by the script in the same way as the non-standard attributes in the modified <td> tags, 
as will be described in detail below. For example, a typical <script> tag is: 
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<script language-javascript src= "http://data.rttp. com /rtml" 
useraame="user" password="pwl23 M flashtime=50O < /script^ 

[0029] A more advanced example is given below: 

<script language = javascript src= l, ../rttp/js/index.js t1 
username=account366 password=h67b89j9 flashtime=1500 
bgup=#3333aa bgdn=#aa3333 bgeq= green fgflash»yellow 
debug" 3> </script> 



[0030] The functionality introduced by the various attributes included in the tags above, together with other attributes 
which can be included in the <script> tags, will be described in detail below. 
20 [0031] The following <script> attributes are for example defined: 
[0032] username e.g. usemame="account366" 

This is a user name submitted to the server which provides the real-time data to identify the user when the page is first 
loaded. If not present in the < script> tag, the default user name ■dummy" is used. 
[0033] password e.g. password= u h67b89j9" 
25 This is a password submitted to the real-time data server for authenticating the user. If not present in the <script> tag , 
the default password "dummy" is used. 
[0034] debug e.g. debug=3 

This defines the errors and events that are reported when a page loads. It can have a value of, for example, 0 to 6, 
where 0 represents error reporting being disabled, 6 represents full error and status information reporting and levels 
30 1 to 5 represent intermediate levels of error reporting. For example, debug level 3 represents full error reporting, but 
without any status information. 

[0035] The real-time placement of quotes onto a web page Is described below with reference to Figure 7. A quote 
is embedded at a particular position in a web page by placing ft into an HTML element at that position. An HTML 
element is defined by a pair of tags between which text can be placed, such as <td>... </td>, <div> ... </div> or <p>... 
35 </p> tags. If no HTML element exists at the location at which the quote is to appear, one can be created by using the 
<span> ... </span> tag. 

[0036] Referring to Figure 7, browser detection is first performed (step s1 0) in a manner well-known per se to deter- 
mine whether the browser is at least Internet Explorer version 4, Netscape Navigator version 6 or some other browser 
which implements a DOM and therefore to determine which DOM should be used. Based on the selected DOM, the 

40 script looks for the <script> tag (step s11), to enable it to read any attributes which have been defined in it (step s1 2). 
[0037] A number of optional attributes are available to control presentation of the information to be shown on the 
screen. For example, the "bgchange" attribute defines what constitutes "up* and what constitutes 'down' for the purpose 
of determining temporary background colour change (flashing) when a value updates. Allowed values are re/ (Relative) 
which specifies that a value greater than the previous value is interpreted as 'up 1 and a value less than the previous 

45 value interpreted as 'down', and abs (Absolute) which specifies that a positive value is interpreted as 'up* and a negative 
value as 'down*. 

[0038] Other optional attributes include "bgdn", "bgup" and "bgeq", which define the colour to be used for the back- 
ground flash for down, up and no change updates respectively. The colour may be any valid HTML colour. Similarly, 
"fgchange", "fgdn", Igup" and "fgeq" attributes define the corresponding up/down definitions and colour changes for 

so the foreground (text) colour change when a value updates. 

[0039] An "fgflash M attribute defines the colour to which the text changes for the duration of the background flash'. 
The purpose of this is to reverse the text so that it is still visible when the background colour changes. 
[0040] The "flashtime" attribute is the length of time in milliseconds for which the background to each element remains 
highlighted, i.e. flashes, when the value of that element is updated. For example, flashtime=500 causes the colour of 

55 each element to change when the value updates and to revert to the original colour half a second later. 

[0041] If an attribute is not specified in the script tag, it is allocated a default value by the script (step s13). 
[0042] The allocated and default values are then written to the document object model by the script, so defining how 
the data retrieved from the data source is to be presented (step s14). 
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[0043] The script then searches for a quote element according to the Invention, which is an extension tag which 
contains the identifier id=QUOTE (step s15). The format of a quote element in accordance with the invention is shown 
below: 

<tag ld=QUOTE attributel attribute2 ... Qattributel Qattribute2 ...> 
5 where attribute 1 , attribute2 etc. are the normal HTML attributes for the tag and Qattributel , Qattribute2 etc. are quote 

attributes that define what information is to be inserted and how it is to be displayed. 

[0044] In the example given in Code Extract 3, the tag format of a quote element is for example: 
<td align = right id=QUOTE symbol="EUR n fid="Bid"> </td> 

[0045] The <td> tag is known to HTML, as are its attributes align and id. The id attribute is used in this case to identify 
10 the tag as an extension tag, i.e. one that contains attributes which are unknown to HTML, but which can be interpreted 

by the script. In the example above, these unknown attributes are 'symbol' and lid 1 . 

[0046] Once a quote element has been found, the script searches for and loads the attributes specified in the element 
(step s1 6). Every quote element requires the 'symbol' and fid' attributes to be defined to specify what is to be displayed, 
either explicitly in the tag or by previously setting default values for the attributes. 

15 [0047] The 'symbol' and lid' attributes reference information, such as financial information, from an external data 
source. For example, Cap! in Systems Ltd., London, UK t have developed a web protocol known as Real Time Text 
Protocol (RTTP), which implements real-time streaming for almost all types of information, including logical records, 
news and free-format pages. RTTP data sources for providing information which is capable of being referenced by the 
symbol and fid attributes are available by subscription over the Internet. 

20 [0046] The 'symbol' attribute specifies the financial instrument to which the quote tag relates. The symbol used to 
identify a particular instrument depends on the symbology being used by the data source. For example, symbol= 7 
IBM.N" represents the Reuters symbology for the real-time price of IBM ordinary shares traded on the New York Stock 
Exchange. The symbols "GBP", "EUR" and "JPY" used in the example above represent different currencies. 
[0049] The 'fid' attribute, which stands for "field identifier", specifies a piece of data relating to the financial instrument 

2$ selected by the 'symbol' attribute. For example, typical values for a particular stock are "Bid", "Ask", "Mid*, "Chng" and 
"CIs", representing the bid price, asking price, mid price, change on the day and previous day's closing price respec- 
tively. The range of 'fids' available for a particular financial instrument depends on the symbology being used by the 
data source. For example, fid= "Ask" displays the most recent price at which the instrument specified by the 'symbol' 
attribute was offered for sale in the market. 

30 [0050] The specified attributes are used to retrieve the data from the real-time data source. For example, a Java 
applet is used to implement a connection between the script and the RTTP server 6 shown in Figure 1 . A request is 
sent via the applet to the RTTP server 6 specifying the required data by means of the symbol and fid attributes (step 
s1 7). The script then waits to receive data from the server (step s1 8). The RTTP server 6 notes the data, request (step 
s19) and sends the latest available value of the updated data to the script (step s20). Every time the value of the 

35 requested data is updated (step s21), the updated value is sent to the script by the RTTP server (step s20). The 
retrieved data is then written into the document object model and is therefore presented in the pre-defined locations 
on the browser screen (step s22). 

[0051 ] While the above method has been described in relation to an RTTP server which provides a source of stream- 
ing data, it will be understood that the invention is not limited to this, but can be implemented with any data source, 
40 including a source from which data can be periodically requested, or by any method by which numerical or other 
information is updated or computed. 

[0052] Although the Web server machine 2 and RTTP server 6 have been shown as separate computers, it will be 
understood that the web server 5 and RTTP server 6 can be server processes running on the same physical machine. 

45 

Claims 

1. A method of processing a hypermedia document, the document comprising: information defined in a hypermedia 
markup language, information which is undefined in the hypermedia markup language and program instructions, 
so the method comprising: 

executing the program instructions to perform a predetermined function in dependence on the undefined in- 
formation. 

55 2. A method according to claim 1 , wherein the program instructions are defined in a scripting language. 

3. A method according to claim 1 or 2, wherein the undefined Information Is embedded In the defined information, 
further comprising extracting the undefined information from the defined information. 
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4. A method according to any one of the preceding claims, wherein the undefined information is referenced through 
a document object model created by a client application from the hypermedia document, further comprising search- 
ing the document object model for the undefined information. 

5 5. A method according to any one of the preceding claims, including retrieving data to be displayed from an external 
source in dependence on the undefined information. 

6. A method according to claim 5, comprising receiving the data continuously in response to a request for the data. 

10 7. A method according to claim 5, comprising retrieving the data periodically. 

8. A method according to any one of claims 1 to 4, including computing data to be displayed in dependence on the 
undefined information. 

*5 9. A method according to any one of claims 5 to 8, further comprising writing the data to be displayed to the document 
object model, whereby the data is displayable by the client application. 

10. A method according to any one of claims 4 to 9, wherein the client application comprises a web browser. 

20 1 1 . A hypermedia document for display by a client application, the document including information defined in a hyper- 
media markup language, information which is undefined in the hypermedia markup language and program instruc- 
tions, the program instructions being executable to perform a predetermined function in dependence on the un- 
defined information. 

25 12. A hypermedia document according to claim 11, wherein the defined information includes a tag having defined 
attributes and the undefined information comprises additional undefined attributes for the tag. 

13. A hypermedia document according to claim 12, wherein the undefined attributes of a given tag specify data items 
to be displayed. 

30 

14. A hypermedia document according to claim 12 or 13, wherein the undefined attributes of a given tag specify how 
data Items are to be displayed. 

15. A hypermedia document according to claim 13 or 14, wherein a first attribute identifies an entity about which 
35 information is to be displayed. 

16. A hypermedia document according to claim 15, wherein a second attribute identifies one of a plurality of charac- 
teristics of the entity. 

to 17. A hypermedia document according to any one of claims 11 to 16, wherein the client application comprises a web 
browser. 

18. A method of providing real-time Information for display as a hypermedia document, the document Including a tag 
defining the location at which the information is to be displayed, the tag being associated with at least one attribute, 

45 comprising: 

retrieving the information to be displayed in dependence on the one or more attributes associated with the 
tag; and 

writing the information to the predefined location in the hypermedia document. 

so 

1 9. A method according to claim 1 8, comprising executing program instructions contained in the document to determine 
an index associated with the or each attribute, said index determining the information which is to be retrieved. 

20. A method according to claim 18 or 1 9, further comprising continuously receiving and writing the information to be 
55 displayed. 

21 . A method according to claim 18 or 19, further comprising periodically retrieving and writing the information to be 
displayed. 
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22. A system for displaying information, comprising: 



means for accessing a hypermedia document; 
a client application for rendering the hypermedia document; 
5 program means associated with the hypermedia document for interpreting information within the hypermedia 

document which is not interpretable by the client application; and 
means for receiving information to be displayed In response to said interpretation. 



23. A system according to claim 22, wherein the hypermedia document includes a tag defining the location at which 
10 the information is to be displayed, the tag being associated with at least one attribute which is interpretable by the 

client application, the information which is not interpretable by the client application comprising additional attributes 
associated with the tag which index the data to be displayed. 

24. A system according to claim 22 or 23, wherein the program means is operative to request the information to be 
is displayed and in response to said request, to receive a stream of information for display. 



25. A system according to claim 22 or 23, wherein the program means is operative periodically to retrieve data to be 
displayed and to provide the data for display. 



20 
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Figure 1 
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Figure 3 




Figure 4 
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Figure 6 
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